CLAIMS 



1 . (Currently amended) A method for processing data packets received from a network, the method 
comprising the steps of: 

(A) storing each received data packet in a buffer; 

(B) dynamically updating a first threshold value based on (i) variation in packet transit time over the 
network and (ii) data packets arriving out-of-sequence; 

(C) performing a comparison based on a waiting time of a data packet and the first threshold value; and 

(D) transmitting the data packet from the buffer for further processing based on the comparison of step (C) a 
wherein: 

the data packets are organized in the buffer into one or more frames, each frame comprising one or 
more data packets: 

the first threshold value is updated every time a new data packet is stored in the buffer; 

each frame is assigned a frame-release threshold based on the first threshold value: 

step (C) comprises the step of comparing the waiting time of an oldest data packet in a current frame to 
the frame-release threshold: and 

step (D) comprises the step of sequentially transmitting all of the data packets in the current frame 
from the buffer for the further processing based on the comparison of step (CY 

2. (Canceled) 

3. (Currently amended) The invention of claim I [[2]], wherein step (D) further comprises the steps of 
starting a new frame and assigning the frame-release threshold for the new frame based on a current value of 
the first threshold value. 

4. (Original) The invention of claim 1, wherein, for each data packet, step (B) comprises the steps of: 
(B 1 ) generating an estimated current packet waiting time; 

(B2) generating a variation measure; 

(B3) generating an out-of-sequence error; and 

(B4) updating the first threshold value based on the estimated current packet waiting time, the variation 
measure, and the out-of-sequence error. 

5. (Original) The invention of claim 4, wherein, for step (B): 

the estimated current packet waiting time corresponds to an integral of variation in packet transit time over 
the network; 
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the variation measure corresponds to jitter in the packet transit time; and 

the out-of-sequence error corresponds to additional waiting time due to the presence of the out-of-sequence 
packets. 

6. (Original) The invention of claim 5, wherein, for step (B4), the first threshold value is limited to be no 
less than a specified lower limit and no greater than a specified upper limit. 

7. (Original) The invention of claim 4, wherein, for step (B), the first threshold value T(i) is set to: 

ifb(i)+vv(i) + e(i)<T min \ 

b(i) + fiv(i) + e(i), ifT min < b(i) + fiv(i) + e(i) < T^; or 

T m ifb(i) + nv(i) + e(i) 2T m wherein: 
b(i) is the estimated current packet waiting time; 
v(i) is the variation measure; 
e(i) is the out-of-sequence error; 
// is a first weighting coefficient; 
T min is a lower limit; and 

is an upper limit. 

8. (Original) The invention of claim 7, wherein for step (B) the out-of-sequence error e(i) is set to: 
e(i) - c(i), ifj(i) > Jmax (i-l)+l, or 

e(i) = c(i) + 00 - / ^-i;; f j/yrO *jm*fl-l), wherein: 
cfjp is a recursive value; 

j(i) is the transmission sequence number corresponding to an i-th packet; 

jmaxO'V is the largest transmission sequence number corresponding to the data packets in the jitter buffer 
prior to arrival of the i-th packet; 

d(i) is packet departure time for the i-th packet; and 

dt is packet departure time for the packet whose transmission sequence number is jmaxO'V- 

9. (Original) The invention of claim 8, wherein for step (B) the recursive value c(i) is set to: 
c(i) = c(i-l), ifj(i) ^Ui-V+l, 

c(i) = c(i-l) + (d(i)-dt(i-l)h if JO) >) max (i-l)+U or 

c(i) = c(i-l)-s(i) 9 ifj(i) <jmaxO'V, wherein: 
c(i-l) is a current value of the recursive value; 
s(i) is the length of the i-th packet. 
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10. (Original) The invention of claim 7, wherein for step (B) the estimated current packet waiting time b(i) 
and the variation measure v(i) are set to: 

b(i) = ab(i-l) + (l-cc)At(i)\ and 

v(i) = a v(i-l) + (1-a) I 6(0 - **(i) 1 , wherein: 
b(i-l) is a current value of the estimated current packet waiting time; 
v(i-l) is a current value of the variation measure; 

At(i) is delay-expected inter-arrival time corresponding to an i-th packet; and 
a is a second weighting coefficient. 

11. (Original) The invention of claim 7, wherein for step (B) the estimated current packet waiting time b(i) 
is set to: 

b(i) = ab(i-l) + (l-a)At(i), ifAt(i) <b(i-l), or 

b(i) = pb(i-l) + (l'P)*t(i)> ifAt(i) > b(i-l); and 

the variation measure v(i) is set to: 

v(i) = av(i-l) + (1-a) I b(i) - At(i) I , wherein: 
b(i-l) is a current value of the estimated current packet waiting time; 
v(i-l) is a current value of the variation measure; 
At(i) is delay-expected inter-arrival time corresponding to an i-th packet; 
a is a second weighting coefficient; and 
P is a third weighting coefficient. 

12. (Original) The invention of claim 1, wherein for step (A) the data packets comprise audio data packets. 

13. (Original) The invention of claim 12, wherein the audio data packets comprise voice over Internet 
Protocol (VoIP) data packets. 

14. (Original) The invention of claim 1, wherein the method is implemented in a processor of an integrated 
circuit. 

15. (Currently amended) A buffer for processing data packets transmitted over a network, comprising: 
a memory configured to store each received data packet; and 

a controller configured to (A) dynamically update a first threshold value based on (i) variation in packet 
transit time over the network and (ii) data packets arriving out-of-sequence; (B) perform a comparison based 
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on a waiting time of a data packet and the first threshold value; and (C) transmit the data packet from the 
buffer for further processing based on the comparison , wherein: 

the data packets are organized in the buffer into one or more frames, each frame comprising one or 
more data packets: 

the first threshold value is updated every time a new data packet is stored in the buffer: 
each frame is assigned a frame-release threshold based on the first threshold value: and 
the buffer is further configured to compare the waiting time of an oldest data packet in a current frame 

to the frame-release threshold and sequentially transmit all of the data packets in the current frame from the 

buffer for the further processing based on the comparison , 

16. (Canceled) 

17. (Currently amended) The invention of claim 15 [[16]] 5 wherein the buffer is further configured to start 
a new frame and assign the frame-release threshold for the new frame based on a current value of the first 
threshold value. 

18. (Original) The invention of claim 15, wherein, for each data packet, the buffer is configured to 
generate an estimated current packet waiting time, a variation measure, and an out-of-sequence error; and to 
update the first threshold value based on the estimated current packet waiting time, the variation measure, and 
the out-of-sequence error. 

19. (Original) The invention of claim 18, wherein: 

the estimated current packet waiting time corresponds to an integral of variation in packet transit time over 
the network; 

the variation measure corresponds to jitter in the packet transit time; and 

the out-of-sequence error corresponds to additional waiting time due to the presence of the out-of-sequence 
packets. 

20. (Original) The invention of claim 19, wherein the first threshold value is limited to be no less than a 
specified lower limit and no greater than a specified upper limit. 

2 1 . (Original) The invention of claim 1 8, wherein the buffer is further configured to set the first threshold 
value T(i) to: 

ifb(i)+nv(i) + e(i)^T min ; 
b(i) + nv(i) + e(i), i/T min < b(i) + nv(i) + e(i) < T^; or 
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Tmax, ifb(i) + fiv(i) + e(i) ZT^, wherein: 
b(i) is the estimated current packet waiting time; 
v(i) is the variation measure; 
e(i) is the out-of-sequence error; 
H is a first weighting coefficient; 
T min is a lower limit; and 
Tmax is an upper limit. 



22. (Original) The invention of claim 21, wherein the buffer is further configured to set the out-of- 
sequence error e(i) to: 

e(0 = c(i), ifj(i) Zjn«x(i-1)+U or 
e(i) = c(i) + (d(i) -dt ifj(i) ZjnUi-lh wherein: 
c(i) is a recursive value; 

j(i) is the transmission sequence number corresponding to an i-th packet; 

jmaxO-1) is the largest transmission sequence number corresponding to the data packets in the jitter buffer 
prior to arrival of the i-th packet; 

d(i) is packet departure time for the i-th packet; and 

dt (i-1) is packet departure time for the packet whose transmission sequence number is jmaxO-V- 

23. (Original) The invention of claim 22, wherein the buffer is further configured to set the recursive value 

c(i) to: 

c(i) = c(i-l), ifj(i) =jUi-V+l, 

c(i) - c(i-l) + (d(i)-ct(i-l)), ifj(i) >j max (i-l)+U or 

c(i) = c(i-l)-s(i), ifj(i) ^j^i-l), wherein: 
c(i-l) is a current value of the recursive value; 
s(i) is the length of the i-th packet. 

24. (Original) The invention of claim 21, wherein the buffer is further configured to set the estimated 
current packet waiting time b(i) and the variation measure v(i) to: 

b(i) = ab(i-l) + (l-a)At(i); and 

v(i) = a v(i-l) + (1-a) I b(i) - At(i) I , wherein: 
b(i-l) is a current value of the estimated current packet waiting time; 
v(i-l) is a current value of the variation measure; 

At(i) is delay-expected inter-arrival time corresponding to an i-th packet; and 
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a is a second weighting coefficient. 

25. (Original) The invention of claim 21, wherein the buffer is further configured to set the estimated 
current packet waiting time b(i) to: 

b(i) = ab(i-l) + (l-a)At(i), ifAt(i) <b(i-l), or 

b(i) = fib(i-l) + (l-fi)At(i) t ifAt(i) > b(i-l); and 

the variation measure v(i) is set to: 

v(i) = a v(i-l) + (1-a) I b(i) - At(i) I , wherein: 
b(i~l) is a current value of the estimated current packet waiting time; 
v(i-l) is a current value of the variation measure; 
At(i) is delay-expected inter-arrival time corresponding to an i-th packet; 
a is a second weighting coefficient; and 
P is a third weighting coefficient. 

26. (Original) The invention of claim 15, wherein the buffer is implemented in an integrated circuit. 

27. (New) A method for processing data packets received from a network, the method comprising the 
steps of: 

(A) storing each received data packet in a buffer; 

(B) dynamically updating a first threshold value based on (i) variation in packet transit time over the 
network and (ii) data packets arriving out-of-sequence; 

(C) performing a comparison based on a waiting time of a data packet and the first threshold value; and 

(D) transmitting the data packet from the buffer for further processing based on the comparison of step (C), 
wherein, for each data packet, step (B) comprises the steps of: 

(B 1 ) generating an estimated current packet waiting time; 

(B2) generating a variation measure; 

(B3) generating an out-of-sequence error; and 

(B4) updating the first threshold value based on the estimated current packet waiting time, the 
variation measure, and the out-of-sequence error, wherein, for step (B): 

the estimated current packet waiting time corresponds to an integral of variation in packet transit 
time over the network; 

the variation measure corresponds to jitter in the packet transit time; and 

the out-of-sequence error corresponds to additional waiting time due to the presence of the out-of- 
sequence packets. 
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28. (New) The invention of claim 27, wherein, for step (B4), the first threshold value is limited to be no 
less than a specified lower limit and no greater than a specified upper limit. 

29. (New) A method for processing data packets received from a network, the method comprising the 
steps of: 

(A) storing each received data packet in a buffer; 

(B) dynamically updating a first threshold value based on (i) variation in packet transit time over the 
network and (ii) data packets arriving out-of-sequence; 

(C) performing a comparison based on a waiting time of a data packet and the first threshold value; and 

(D) transmitting the data packet from the buffer for further processing based on the comparison of step (C), 
wherein, for each data packet, step (B) comprises the steps of: 

(B 1 ) generating an estimated current packet waiting time; 

(B2) generating a variation measure; 

(B3) generating an out-of-sequence error; and 

(B4) updating the first threshold value based on the estimated current packet waiting time, the 
variation measure, and the out-of-sequence error, wherein, for step (B), the first threshold value T(i) is set to: 
ifb(i) + nv(i) + e(i) <T min ; 
b(i) + nv(i) + e(i), ifT min < b(i) + fiv(i) + e(i) < T„; or 
Tnum ifb(i) + fiv(i) + e(i) ZTmax, wherein: 

b(i) is the estimated current packet waiting time; 

v(i) is the variation measure; 

e(i) is the out-of-sequence error; 

Ii is a first weighting coefficient; 

T min is a lower limit; and 

Tmax is an upper limit. 

30. (New)The invention of claim 29, wherein for step (B) the out-of-sequence error e(i) is set to: 
e(i) = c(i) 9 ifj(i) > Jmax (i-l)+l 9 or 

e(i) = c(i) + (d(i) - cT(i-l)), ifj(i) Zj^iUlh wherein: 
c(i) is a recursive value; 

is the transmission sequence number corresponding to an i-th packet; 
jmaxG'l) is the largest transmission sequence number corresponding to the data packets in the jitter 
buffer prior to arrival of the i-th packet; 

d(i) is packet departure time for the i-th packet; and 

dt (i-1) is packet departure time for the packet whose transmission sequence number is jmaxfi-V- 
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3 1 . (New) The invention of claim 30, wherein for step (B) the recursive value c(i) is set to: 

cv-co-ij.im-jui-v+i* 

c(i) = c(i-l) + (d(i) - (f(i-l)) 9 ifj(i) >j max (i-l)+l, or 
c(i) = c(i-l)-s(i) 9 ifj(i) ^j^i-l), wherein: 

c(i-l) is a current value of the recursive value; 

s(i) is the length of the i-th packet. 

32. (New) The invention of claim 29, wherein for step (B) the estimated current packet waiting time b(i) 
and the variation measure v(i) are set to: 

b(i) = ab(i-l) + (l-a)At(i)\ and 

v(i) = a v(i-l) + (7-<z; 1 6$ - 4/(# I , wherein: 

6(7-/,) is a current value of the estimated current packet waiting time; 

v(i-l) is a current value of the variation measure; 

At(i) is delay-expected inter-arrival time corresponding to an i-th packet; and 
a is a second weighting coefficient. 

33. (New) The invention of claim 29, wherein for step (B) the estimated current packet waiting time b(i) is 
set to: 

b(i) = ab(i-l) + (l-a)At(i), ifAt(i) <b(i-l), or 

b(i) = fibfl-1) + (1-P)W)> if*t(i) > b(i-J); and 

the variation measure v(i) is set to: 

v(i) - a v(i-l) + (1-a) I b(i) - At(i) I , wherein: 

b(i-l) is a current value of the estimated current packet waiting time; 

v(i-l) is a current value of the variation measure; 

At(i) is delay-expected inter-arrival time corresponding to an i-th packet; 

or is a second weighting coefficient; and 

P is a third weighting coefficient. 

34. (New) A buffer for processing data packets transmitted over a network, comprising: 
a memory configured to store each received data packet; and 

a controller configured to (A) dynamically update a first threshold value based on (i) variation in packet 
transit time over the network and (ii) data packets arriving out-of-sequence; (B) perform a comparison based 
on a waiting time of a data packet and the first threshold value; and (C) transmit the data packet from the 
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buffer for further processing based on the comparison, wherein, for each data packet, the buffer is configured 
to generate an estimated current packet waiting time, a variation measure, and an out-of-sequence error; and to 
update the first threshold value based on the estimated current packet waiting time, the variation measure, and 
the out-of-sequence error, wherein: 

the estimated current packet waiting time corresponds to an integral of variation in packet transit time 
over the network; 

the variation measure corresponds to jitter in the packet transit time; and 

the out-of-sequence error corresponds to additional waiting time due to the presence of the out-of- 
sequence packets. 

35. (New) The invention of claim 34, wherein the first threshold value is limited to be no less than a 
specified lower limit and no greater than a specified upper limit. 

36. (New) A buffer for processing data packets transmitted over a network, comprising: 
a memory configured to store each received data packet; and 

a controller configured to (A) dynamically update a first threshold value based on (i) variation in packet 
transit time over the network and (ii) data packets arriving out-of-sequence; (B) perform a comparison based 
on a waiting time of a data packet and the first threshold value; and (C) transmit the data packet from the 
buffer for further processing based on the comparison, wherein, for each data packet, the buffer is configured 
to generate an estimated current packet waiting time, a variation measure, and an out-of-sequence error; and to 
update the first threshold value based on the estimated current packet waiting time, the variation measure, and 
the out-of-sequence error, wherein the buffer is further configured to set the first threshold value T(i) to: 

T mint 

b(i) + fivCi) + e(0, i/T min < b(i) + fiv(i) + e(i) < T^; or 
T m ifb(i) + fiv(i) + e(i) > T m wherein: 

b(i) is the estimated current packet waiting time; 

v(i) is the variation measure; 

e(i) is the out-of-sequence error; 

/i is a first weighting coefficient; 

T min is a lower limit; and 
is an upper limit. 

37. (New) The invention of claim 36, wherein the buffer is further configured to set the out-of-sequence 
error e(i) to: 

e(0 = c(i) 9 ifj(i) > Jmax (i-l)+l, or 
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e(i) = c(i) + (d(i) - dt (i-lfr ifjO) ^0-1), wherein: 
c(i) is a recursive value; 

j(i) is the transmission sequence number corresponding to an i-th packet; 

jmaxO-V is the largest transmission sequence number corresponding to the data packets in the jitter 
buffer prior to arrival of the i-th packet; 

d(i) is packet departure time for the i-th packet; and 

dt (i-1) is packet departure time for the packet whose transmission sequence number is jmaxO-l). 



38. (New) The invention of claim 37, wherein the buffer is further configured to set the recursive value 

c(i) to: 

c(i) = c(i-l) + (d(i) - <f(i-l)), ifj(i) >j max (i-l)+l, or 
c(i) = c(i-l)-s(i), ifj(i) <j max (i-l), wherein: 

c(i-l) is a current value of the recursive value; 

s(i) is the length of the i-th packet. 

39. (New) The invention of claim 36, wherein the buffer is further configured to set the estimated current 
packet waiting time b(i) and the variation measure v(i) to: 

b(i) = ab(i-l) + (l-a)At(i)\ and 

v(i) = a v(i-l) + (1-a) I b(i) - At(i) I , wherein: 

b(i-l) is a current value of the estimated current packet waiting time; 

v(i-l) is a current value of the variation measure; 

At(i) is delay-expected inter-arrival time corresponding to an i-th packet; and 
a is a second weighting coefficient. 

40. (New) The invention of claim 36, wherein the buffer is further configured to set the estimated current 
packet waiting time b(i) to: 

b(i) = ab(i-l) + (l-a)At(i), ifAt(i) <b(i-l), or 

b(i) = pb(i-l) + 0-P)*t(i)> ifW) > b(i-l); and 

the variation measure v(i) is set to: 

v(i) = a v(i-l) + (1-a) I b(i) - At(i) I , wherein: 

b(i-l) is a current value of the estimated current packet waiting time; 

v(i-l) is a current value of the variation measure; 

At(i) is delay-expected inter-arrival time corresponding to an i-th packet; 
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a is a second weighting coefficient; and 
P is a third weighting coefficient. 
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